package thread.unit1.learncreate;
//测试Thread中的常用方法：
//* 1. start():启动当前线程；调用当前线程的run()
//* 2. run(): 通常需要重写Thread类中的此方法，将创建的线程要执行的操作声明在此方法中
//* 3. currentThread():静态方法，返回执行当前代码的线程
//* 4. getName():获取当前线程的名字
//* 5. setName():设置当前线程的名字
//* 6. yield():释放当前cpu的执行权
//* 7. join():在线程a中调用线程b的join(),此时线程a就进入阻塞状态，直到线程b完全执行完以后，线程a才
//*           结束阻塞状态。
//* 8. stop():已过时。当执行此方法时，强制结束当前线程。--不推荐
//* 9. sleep(long millitime):让当前线程“睡眠”指定的millitime毫秒。在指定的millitime毫秒时间内，当前
//*                          线程是阻塞状态。
//* 10. isAlive():判断当前线程是否存活

//线程的优先级：
//* 1.
//* MAX_PRIORITY：10 -->最高优先级
//* MIN _PRIORITY：1 -->最低优先级
//* NORM_PRIORITY：5  -->默认优先级
//* 2.如何获取和设置当前线程的优先级：
//*   getPriority():获取线程的优先级
//*   setPriority(int p):设置线程的优先级
//*
//*   说明：高优先级的线程要抢占低优先级线程cpu的执行权。但是只是从概率上讲，高优先级的线程高概率的情况下
//*   被执行。并不意味着只有当高优先级的线程执行完以后，低优先级的线程才执行。
//*

public class ThreadMethodDemo1 {
    public static void main(String[] args) {
        ThreadTest threadTest = new ThreadTest();
        threadTest.setName("子线程");
        threadTest.start();
        //设置线程的优先级
        Thread.currentThread().setPriority(8);
        threadTest.setPriority(Thread.MAX_PRIORITY);

        System.out.println(Thread.currentThread().getName()+"优先级："+Thread.currentThread().getPriority());
        //如下操作仍然是在main线程中执行的。两个线程并发执行
        for (int i = 0; i < 100; i++) {
            if (i % 2 == 0) {
                System.out.println(Thread.currentThread().getName() + ":" + i + "***********main()************");
            }
            if (i ==50){
                try {
                    threadTest.join();

                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}
class ThreadTest extends Thread{
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+"优先级："+Thread.currentThread().getPriority());
        for (int i = 0; i < 100; i++) {
            if (i % 2 == 0) {
                System.out.println(Thread.currentThread().getName() + ":" + i );
            }
            if (i % 20==0){
                //释放cpu控制权
//                this.yield();
            }
        }
    }
}